$(function () {
    var layer = layui.layer;
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 4 / 3,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options);

    //为上传按钮绑定点击事件
    $('#btnChooseImage').on('click', function () {
        $('#file').click();
        //模拟点击事件
    });

    //监听图片变换事件
    $('#file').on('change', function (e) {
        //获取用户选择的文件
        var filelist = e.target.files;
        // console.log(filelist);
        if (filelist.length === 0) {
            return layer.msg('请选择照片!');
        }

        //更改裁剪区域
        var file = e.target.files[0];
        //将文件转换为路径
        var imgURL = URL.createObjectURL(file);
        //重新初始化裁剪区域
        $image
            .cropper('destroy')//销毁就的裁剪区域
            .attr('src', imgURL)//重新设置图片路径
            .cropper(options);//重新吃啥裁剪区域

    });

    //监听绑定提交图片按钮
    $('#btnUpload').on('click', function () {
        // 拿到裁剪之后的头像，把头像上传到服务器
        // canvas.toDataURL('image/png')这里需要解决cors跨域问题
        var dataURL = $image
            .cropper('getCroppedCanvas', {
                // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png')
        // 转换为base64格式的字符串
        // 使用post上传头像
        $.ajax({
            method: 'POST',
            url: '/my/update/avatar',
            data: {
                avatar: dataURL
            },
            success: function (res) {
                if (res.status !== 0) {
                    return layer.msg('更换头像失败!');
                }
                layer.msg('更换头像成功!');
                window.parent.getUserInfo();
            }

        })
    });
});